$(function(){
    let layer = layui.layer
    let form = layui.form
    initEditor()
    initCate()
    // 定义加载文章分类的方法
    function initCate() {
        $.ajax({
            method : 'GET',
            url : 'my/article/cates',
            success : function(res) {
                if(res.status !==0) {
                    return layer.msg('获取下拉失败')
                }
                // layer.msg('获取列表成功')
                let htmlStr = template('tpl-cate',res)
                $('[name=cate_id]').html(htmlStr)
                form.render()
            }
        })
    }

    // 1. 初始化图片裁剪器
var $image = $('#image')

// 2. 裁剪选项
var options = {
  aspectRatio: 400 / 280,
  preview: '.img-preview'
}

// 3. 初始化裁剪区域
$image.cropper(options)


// 为封面选择按钮绑定点击事件
$('#btnChooseImage').on('click',function(){
    $('#coverFile').click()
})

// 监听file文件选择框的change事件
$('#coverFile').on('change',function(e){
    let files = e.target.files
    if(files.length ===0) {
        return
    }
        // 根据文件，创建对应的 URL 地址
        var newImgURL = URL.createObjectURL(files[0])
        // 为裁剪区域重新设置图片
        $image
          .cropper('destroy') // 销毁旧的裁剪区域
          .attr('src', newImgURL) // 重新设置图片路径
          .cropper(options) // 重新初始化裁剪区域
})

// 定义文章的发布状态
let art_state = '已发布'
$('#btnSave2').on('click',function(){
    art_state = '草稿'
})

// 为表单绑定submit事件
$('#form-pub').on('submit',function(e){
     // 1. 阻止表单的默认提交行为
    e.preventDefault()
      // 2. 基于 form 表单，快速创建一个 FormData 对象  
    let fd = new FormData(this)
          // 3. 将文章的发布状态，存到 fd 中
    fd.append('state',art_state)
    
    // fd.forEach(function(v,k){
    //     console.log(k,v);
    // })
      // 4. 将封面裁剪过后的图片，输出为一个文件对象
  $image
  .cropper('getCroppedCanvas', {
    // 创建一个 Canvas 画布
    width: 400,
    height: 280
  })
  .toBlob(function(blob) {
    // 将 Canvas 画布上的内容，转化为文件对象
    // 得到文件对象后，进行后续的操作
    // 5. 将文件对象，存储到 fd 中
    fd.append('cover_img', blob)
    // 6. 发起 ajax 数据请求
    publishArticle(fd)
  })
})

function publishArticle(fd) {
$.ajax({
    method : 'POST',
    url : 'my/article/add',
    data : fd,
    contentType : false,
    processData : false,
    success : function(res) {
        if(res.status !==0) {
            return layer.msg('发布文章失败')
        }
        layer.msg('发布文章成功')
        // 发布文章成功后，跳转到文章列表页面
        location.href = '/article/art_list.html'
    }
})
}
})